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FIEIJD OF THE INVENTION 

The invention relates to a broadcast system for broadcasting at least one title 
using a near-video-on-demand broadcasting protocol, where the system includes a plurality 
of broadcast receivers and a hierarchical network of data distributors starting from a central 
5 distributor through at least one layer of intermediate distributors to the broadcast receivers. 
The invention also relates to a method of broadcasting data streams. The invention further 
relates to a broadcast receiver, distributor and filter controller for use in such a system. 

BACKGROUND OF THE INVENTION 

1 0 Conventional broadcasting s^^tems, such as cable networks, for broadcasting 

data streams to a plurality of broadcast receivers use a hierarchical network of data 
distributors. The top of the network is formed by one central headend, the bottom layOT of 
devices is formed by the residential broadcast receivers. As an example, a system aimed at 
broadcasting audio/video to a total of 200,000 homes may use a hierarchy of seven layers of 

1 S devices. At the top, the master headend may siq>ply data to five metropolitan headends, each 
covering a disjoint metropolitan area. Each of these areas may be divided further over five 
hubs with direct links between the metropolitan headend and tho hubs. Each of the hubs may 
be directly connected to twenty fiber nodes from which in turn four coax cables are leaving. 
Each coax cable connects up to one hundred homes. 

20 Typically the coaxial cable has a capacity in the order of one gigabit per 

second doAvnstream (i,e, in the direction towards the broadcast receiver). Some of this 
capacity is reserved for conventional broadcast channels, like the most popular television 
stations. Such channels can in principle be received by all broadcast receivers (i.e. it is 
transmitted via all coax cables^ although actual receipt may be conditional upon payment. A 

25 small part of the bandwidth tends to be reserved for upstream communication from the 
broadcast receiver up through the network to an interested party. Usually, this iq)stream 
communication is to the hitemet, using broadband cable modems. It may also be to a service 
provider for interactive applications. With the remaining bandwidth, it is difficult if not 
infeasible to provide an effective video-on-draiand service where a significant portion of tiie 
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receivers can simultaaeously receive a title (e.g. movie) whose supply is started substantially 
immediately after the user having indicated that it vnshes to receive the title. To overcome 
this, so-called near-video-on demand broadcast distribution protocols have been developed 
wherein a title is repeatedly broadcast using a group of a plurality of broadcast channels. A 
highly effective protocol is the Pagoda broadcasting protocol described in "A fixed-delay 
broadcasting protocol for video-on-demand", of J.-F. PSris, Proceedings of the 10* 
Intemational Conference on Conq)uter Communications and Networks, pages 418-423. In 
this protocol, after an initial delay of, for example, one minute the broadcast receiver can 
render the title in real-time by retrievmg the blocks firom a plurality of channels where the 
protocol prescribes in which channel a block is transmitted and the sequence of transmission 
of blocks in a channel. Typically, the receiver needs to tap a few of the group of channels 
(e.g. two channels) to avoid underflow of data. The repetition rate of the first channel is the 
highest, resulting in a relatively low initial delay. The repetition rate of the last channel is the 
lowest (this chaimel can be used to transmit most different blocks). To support simultaneous 
transmission of a large collection of near-video-on demand movies (e.g. 1000 movies) the 
broadcast system needs a high bandwidth. For the levels between the master headend and Ihe 
fiber nodes this can easily be achieved using suitable dedicated links, such as nsing fiber 
optic based distribution. Particularly at the lowest level, use of a shared medium, such as 
coax, is most economical. The bandwidth of the shared medium is not sufficient for 
broadcasting of a relatively large number of near-video-on-demand titles. This hampers the 
introduction of such systems. 

SUMMARY OF THE INVENTION 

It is an object of the invention to provide a near-video-on-demand system and 
devices used in such system that can support broadcasting of more titles. 

To meet the object of the invention, a broadcast system for broadcasting at 
least one title using a near-video-on-demand broadcasting protocol includes a plurality of 
broadcast receivers; a hierarchical network of data distributors starting firom a central 
distributor through at least one layer of intermediate distributors to the broadcast receivers for 
broadcasting the title as a sequence of data blocks; and at least one filter controller operative 
to receive requests from broadcast receivers for the supply of the title and for controlling at 
least one intermediate distributor to filter out data blocks of the titie tiiat have not been 
requested by receivers hierarchically below the intermediate distributor. By filtering out 
blocks that axe not leqmred, capacity is fireed at the network below the intermediate 
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distributor. This capacity can be used by the central distributor to broadcast more titles. The 
filtCT controller monitors which titles are required by the lower networic segments and 
controls the filtering accordingly. 

As described by (he measure of the dependent claim 2, data blocks of the title 
are broadcast via a pluraUty of channels using sequential time-slots within the channels 
accordmg to a near-video-on-demand schedule that for each data block of the title prescribes 
a time-slot and channel for broadcastmg the data block relative to a time-slot used fi>r 
broadcasting a first data block of the title; data blocks assigned to a channel being repeatedly 
broadcast within the channel; the filter controller bemg operative to: store information on aU 
receivers hierarchically below the intermediate distributor that have requested the title 
(herdnafter "interested receivers") to enable the filter controller to determine for each 
channel whether at least one of fiie raterested receivers needs to receive a data block assigned 
to the channel; and control the intermediate distributor to filter out a channel if no interested 
receiver needs to receive a data block assigned to the channel. The filter controller stores 
information on the interested receivers, such as the time-slot in which it started reception of 
the title and/or the currrait time-slot and/or data block being received. Such information 
enables the filter controller to determine whether or not a channel needs to be broadcast (it 
needs to be broadcast if at least one interested receiver is still tapping it). If no interested 
receiver is tapping a channel, the entire channel can be filtered out and used for other 
purposes for example for broadcasting another near-video-on demand title. 

As described by the measure of the dependent claim 3, the near-video-on- 
demand schedule prescribes fhat data blocks of the title are broadcast via c parallel equal 
c^adty channels of the broadcast system, where each broadcast channel is associated with a 
respective sequential chamiel number, the title bemg divided in a plurality of consecutive 
data block sequences; each block sequence bemg assigned to one respective channel 
according to the sequence of the channel numbers; each channel repeatedly broadcasting the 
assigned block sequence; the broadcast receiver having a capacity to simultaneously receive a 
pluraHty r (l<r^ c) of the channels; the broadcast receiver bemg operative to receive a tide 
by starting reception of the sequentially lowest r channels and each tune in response to 
having received all blocks of the block sequence of a channel i terminating reception of 
channel / and starting reception of channel r+ / until all block sequences have been received. 
Such a Pagoda-style broadcasting schedule enables tiie filter controUer to simply determine 
for each channel whether or not a data block is requked in the next time-slot purely based on 
the first time-slot used by the recovers. As such, the filter controller only needs to know the 
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start of reception and needs no continuous flow of infonnation from the receivers to be able 

to control the filtering on a channel level. 

As described by the measure of the dependent claim 4, the Pagoda-style 
broadcasting schedule enables the filter controller to even filter at a sub-channel level, where 
a channel is divided in time-multiplexed sub-channels. 

Similarly, as described by the measure of the dependent claim 5, the Pagoda- 
style broadcasting schedule enables the filter controller to even filter at a datablock level. 

As described by the measure of the dependent claim 6, the channels are lime- 
multiplexed. By time-multiplexing the channels. r&-use of the channel is simplified, hi fact, 
filtering out a channel, sub-channel or mdividual block all result in fireemg up one or more 
time-slots that can be re-used for other purposes. 

As described by the measure of the dependent claim 7, the intermediate 
distributor is operative to extract data blocks broadcast via the r channels to be received by at 
least one interested receiver and transmit the extracted data blocks via predetermined 
channels to the interested receivers. Particularly if atitleis not received by many receivers 
using different time-slots, this is an effective way of reducmg AT channel to only r channels. 
All the remaining N-r channels used for the title can be filtered out 

As described by the measure of the dependent claim 8, the intermediate 
distributor includes the filter controller. This simplifies interaction between both parties. 

As described by the measure of the dependent claim 9, at least one of the 
broadcast receivers is operative to communicate to the filter controller via an upstream 
channel of the broadcast system Using the upstream channel is an effective way of 
communicating with flie filter controller. Particularly if the filter controller is combmed with 
the mtermediate distributor up-stream communication can simply be intercepted by the filter 
controller without the broadcast receiver requiring any knowledge of the network topology 
and/or location of the distributor(s) and/or filter controller(s). 

These and other aspects of the invaition are apparent fiwm and wiU be 
elucidated with reference to the embodiments described herdnafter. 

BRIEF DESCRIPTION OF THE DRAWINGS 
In the drawings: 

Fig. 1 shows an exemplary hierarchical broadcast networic in which the 
inv^tion can be employed; 
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Fig. 2 shows block diagram of the broadcast system according to the 

invention; 

Figs3 A and 3B illustrate the Pagoda NVoD protocol; 
Fig, 4 illiistrates adding a channel in the Pagoda protocol; 
5 Fig, 5 illustrates the blocks actually read by the receivers; 

Fig. 6 shows tiie expected number of used channels for one movie; 
Fig. 7 shows a Markov chain that describes the states of a minimal 
transmission scheme; 

Fig. 8 shows a lower bound on the expected number of chaimels needed for a 

10 movie; 

Fig. 9 shows a second bound on the expected number of channels needed for a 
movie based on optimal block periods and selective transmission; 

Fig. 10 compares the graphs of Figs. 6, 8 and 9; and 

Fig. 1 1 shows the ratio between the two selective transmission schedules and 
15 the lower bound. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 

Fig.2 shows a block diagram of the broadcast system according to the 
invention. The broadcast system 100 includes a hierarchical network of data distributors. The 

20 top of the network is formed by a central distributor 110. The system includes at least one 
layer of intermediate distributors. To simply the figure, only one intermediate layer for 
downstream broadcasting is shown with three intermediate distributors 120, 130 and 140, 
each covering a disjoint geographical area. Fig.l shows a typical hierarchical network for a 
town of 200,000 connected homes, with three intermediate downstream layers (metro 

25 headend, hub, fiber node). In the example, four coax segments are coimected to each fiber 
node. Fig.2 also indicates the downstream path 160 that starts at the central distributor 110, 
runs through the intermediate distributors 120, 130 and 140 and ends at the plurality of 
broadcast receivers of the system. Conventionally the distributors split the broadcast signal 
towards the receivers/distributors that are hierarchically one layer lower. For simplicity only 

30 one broadcast receiver 150 is shown. Typically, the path is divided into a plurality of 

channels, that each may be sub-divided into sub-channels. At the lowest level, usually coaxial 
segments are used that form a shared medium to the broadcast recdvers. On coax, channels 
are usually firequency multiplexed. Sub-channels within such a channel may be tim^ 
multiplexed. At flie higher levels, typically fiber optics is used. On such media, channels may 
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also be timfr-imiltiplexed. Any suitable transmission technology, such as various types of 
media and multiplexing techniques, may be used. The broadcast system is described for 
broadcasting digital data streams through the network to the pluraHty of broadcast receivers 
using a near-video-on-demand protocol (NvoD). The data streams may have been encoded 
using any suitable technology, such as MPEG2 video encoding. Broadcast data is not 
addressed to a specijac receiver and can in principle be received by all receivers in all 
segments of the hierarchical network. Access to the data may be subject to payment. In Hie 
broadcast system according to the mvention access may also be controlled using suitable 
conditional access mechanisms. For each device of the system. Fig. 2 schematically shows 
the respective hardware/software ftmctionaKty 1 12, 122, 132, 142 and 152 necessary for 
sending^receiving broadcast data and performing all necessary processing. In itself such 
HW/S W is known and can be used for the system according to the invention. The HW/SW 
may be formed by suitable transceivCTs (such as fiber optics transceiver and/or cable 
modems) controlled by using suitable processors, such as signal processors. Also dedicated 
hardware, like MPEG encodars/decoders, buffers, etc. may be used. 

Traditionally, all data streams are inserted by the central distributor 1 10 and 
unmodified copied by each intermediate layer to the lowest part of the network (i.e. the signal 
is split). For the insertion, the central distributor may have a storage 115 for storing a 
plurality of titles, such as movies. It may also have a connection 160 for receiving live 
broadcasts, e.g. through sateUite connections. The storage maybe implemented on suitable 
server platforms, for example based on RAID systems. The receiver also has access to a 
storage 155. This storage may also be formed by a hard disk or solid state memory, such as 
RAM of flash memory. The storage is used for (temporarily or permanently) storing the 
entire tifle or part of the title received via the downstream channels before the titie is 
rendered. Fig. 2 also shows an upstream channel 170 of the networic towards the central 
distributor. In principle, the upstream channel may start at an intermediate level going 
upwards. Preferably, the upstream channel is akeady present at the lowest level, also 
allowing communication to outside tiie broadcast system (e.g. towards the Internet via the 
central distributor or an intermediate distributor outwards). 



Filtering 

To support simultaneous transmission of a large collection of near-video-on 
demand movies (e.g. 1000 movies) the broadcast system needs a high bandwidth. For the 
levels between the master headend and the fiber nodes this can easily be achieved using 
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suitable dedicated links, such as using fiber optic based distribution. Pairticularly at the lowest 
level, use of a shared medium, such as coax, is most economical. By selectively filtering data 
according to the invention, for example in the fiber optic node, and only passing on data for 
which there is at least one interested receiver the bandwidth can be sufficient for 
simultaneous distribution of a relatively large number of movies. Note that also at higher • 
levels in the network already a selection can be jnade, e.g., a hub only has to forward the 
blocks of the movies that will be consumed by any user in its sub-tree; the others do not have 
to be forwarded. 

To be able to filter, the system includes at least one filter controller operative 
to controlling at least one intermediate distributor to filter out data blocks of the title that 
have not been requested by receivers hierarchically below the intermediate distributor. Fig.2 
shows one central filter controller 180. Preferably, the system includes a plurality of filter 
controllers, where advantageously each filter controller controls one intermediate distributor 
and may be combmed with it. For the filter controller to be able to determine whether there 
are receivers that need certain data blocks of a title, it directly or indirectly receives requests 
from broadcast receivers for the supply of the title. Preferably, it receives this information 
directly from the receiver via an upstream channel of the network. Depending on the NVoD 
protocol being vised, it may be sufficient for the filter controller to know the start (e,g. time- 
slot of first block) of reception by each receiver that is part of the network segment controlled 
by the controller. This is for example the case with fixed-delay NVoD broadcasting 
schedules, such as Pagoda. Such schedules prescribe for each data block of the title a time- 
slot and channel (and/or sub-channel within the channel) for broadcasting the data block 
relative to a time-slot used for broadcasting a fixst data block of the title. For other schedules, 
it may be required that the filter controller is more regularly updated on the blocks required 
by the receivers. The. filter controller stores information on all recovers hierarchically below 
the intermediate distributor that have requested the titie (hereinafter "interested receivers'*) to 
be able to determine for each chaimel whether at least one of the interested receivers needs to 
receive a data block assigned to the chaimel at each point in time. For the described fixed- 
delay schedules, the filter controller only needs to store the time-slot of the first data block 
consumed by the receiver. Since these schedules prescribe the entire block transmission 
schedule, in principle also other information, such as the block cuirentiy being consumed, is 
sufficient to determine if in the next time-slot the receiver needs data block(s) and, if so, via 
which channel/sub-channel. Filtering may take place m several ways, e.g. broadcasting via a 
channel may be stopped for one or more blocks or broadcasting via a sub-channel may be 
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stopped for one or more blocks. The filtering may take place for each individual time-slot or 
only for sequences of time-slots, e.g. &at correspond to a sequence of blocks of a title being 
repeatedly broadcast via a channel or sub-chaimeL The filter controller may instruct the 
intermediate distributor for each time-slot whether or not to pass on a data block received 
5 6x>m the central distributor. It will be appreciated that bandwidth saved by filtering out 
(sequences of) blocks can be re-used. Re-use may be particularly simple if channels in the 
system are time-multiplexed. For such systems, typically time-slots that are not used can be 
used for other purposes, e.g. for other isochronous channels (either broadcast, multi-cast or 
directly addressed) or for asynchronous data. For systems that use firequency multiplexed 

10 chaxmels, the filter controller may instruct the intermediate distributor how to map the (too 
many) incoming channels to the fewer outgoing chaimels. For filtering of small sequences (or 
even individual blocks), the filter controller may need to inform the broadcast receivers (e.g. 
via a directly addressed message) on which firequency it can receive the channels. Particularly 
for the fixed delay schedules, the filter controller can regularly calculate such a mapping of 

1 5 channels to firequencies. It may even broadcast such a schedule to the receivers. 

In a preferred embodiment, the intermediate distributor may compose channels 
for one or more of the receivers from the streams broadcast to the distributor. This is 
particularly efifective if there are relatively few receivers interested in tiie title at that moment 
and/or if they are watching almost the same sequence. To this end, the distributor extracts 

20 data blocks of a title required by the receivers from a group of channels dedicated to the title 
and re-broadcasts them towards the receivers using fewer chaimels. In the examples given 
below for tibie Pagoda schedule this may involve extracting blocks from c channels assigned 
to the titie and re-broadcasting the blocks using only r channels. 

The filtering according to the invention wiE be described with reference to the 

25 Pagoda NVoD broadcasting protocol. Persons skilled in the art will be able to apply the same 
principles to other schedules as well. 



Fixed-delay Pagoda broadcasting 

Preferably, the fixed-delay Pagoda broadcasting protocol is used as the near- 
30 video-on-demand protocol for broadcasting data blocks of the tides. This protocol is 

asymptotically optimal, and it can easily be adapted to Umited client 1/0 bandwidth, A small 
example of this is given in Fig.3A. Fig.3B shows how the retrieval takes place for a request at 
an arbitrary moment, la the example of Fig. 3, at most two channels are tapped at the same 
time, and all blocks arrive in time. Key in this NVoD scheme is fbat channel i starts being 
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tapped after the tapping of chaimel /-2 has finished, thereby limiting the number of channels 

to be tapped to two. This means e.g. that for channel 4 a receiver has to wait two time units 

before it can start tapping the channel. As block 7 has to be received within 7 time units after 

the request, this means that only 5 time units are left to receive it, and hence it has to be 

5 transmitted with a period of at most 5, rather than 7. It is actually transmitted with a period of 

4. The general structure of the above broadcast scheme will be described for a given number 

c of server channels and a given number r of client channels that can be received. 

Furthermore, an offset o is considered as described meaning that a user will always wait an 

additional o time units before playing out. The start of the (tapping) segment in channel i is 

10 denoted by and the end by Ci. Then, in order not to exceed the maximum number r of 

channels that a user can receive, tapping in channel .-.,c is started after the tapping in 

chaimel z-r has ended. Hence 

1 forz=l,...r 
[e^^y +1 for z = r + 1,..-, c 

Next, in channel / blocks li,...,hi are transmitted. The number of different 
15 blocks transmitted in channel i is hence given by «,* = hi - + i, and 

_ fl for/ = l 
' ^\/i^+l for/>l 

Li order to receive each block in time, block k is to be transmitted in or before 
time unit o+fc. If block k is transmitted in channel i, which starts being received in time xmit 
Si^ this means that block k should be broadcast with a period of at most o+k-(srl)* Ideally, 
20 this period is exactly met for each block but it is sufficient to get close enough. 

The structure of chaimel i in the pagoda scheme is as follows. First, channel i 
is divided into a number rf, of sub-channels, which is given by 

d, = [lo+l,-{s,-l)] (1) 

i.e., the square root of the optimal period of block //, rounded to the nearest integer. Each of 
25 these sub-channels gets a jfraction 1/di of the time units to transmit blocks, in a roimd-robin 

fashion. In other words, in time unit t sub-channel t mod df can transmit a block, where we 

numba: the sub-channels OJ,.,,,dr^. 

Now, if a block k is given a period pk witiiin a sub-channel of channel z, it is 

broadcasted in chaimel i with a period of pk du H^ce, to obtain that p^ di ^-^k-fsrVy 
30 means that 
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By taking equal periods for all blocks within each sub-channel, collisions can 
be trivially avoided. So, if Uj is the lowest block number in sub-channel j of channel i, this 
means that the following period is chosen 
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for all blocks within sub-channel J of chamel i, and hence we can transmit n^=/7j^blocks 
(blocks ly,...,ly+nff-\) in this sub-channel. The block number ly is given by 
^ % fory = 0 

The total number »/ of blocks transmitted in channel i is then given by 
d,-i 

10 »/=Z»tf 

with which we can compute /t( = + 1. 

Finally, the moment of start and end of the segments within a chaimel is 
reviewed. All sub-chamiels of channel i start transmitting at time su Sub-channel j of channel 
i is ready after ny blocks, which takes di ny time units within channel t Hence, the end of the 
15 segment in sub-channel J is given by etj=Si-l + dt ny, and chaimel i ends when its last sub- 
channel ends, at 

= ^iA-i = -5/ - 1 + di^i^-x 
To exemplify the above, Fig.4 illustrates adding a fifth chaimel to the example 
of Fig.3. For the fifth channel, the following holds: h = 12, ^5=63+1=6, and an offeet o=0. 
20 The number of sub-channels is As = [>/(0+12-5)] = 3. For sub-channely=0 this gives /sj) = 12, 
hence we can transmit o =L(0+12-5)/3j = 2 blocks in this sub-channel, benig blocks 12 
and 13. For sub-channel 7=1 this gives Zs,! = 14, hence we can transmit 
»si =L(0+14-5)/3j=3 blocks in this sub-channel, being blocks 14, 15, and 16. Forsub- 

diannely=2 this gives /5;j = 17, hence we can transmit =L(0+17-5)/3j = 4block8in 

25 this sub-channel, being blocks 17, 18, 19, and 20. The end of the segments in the sub- 
channels are given by 65.0 = 5 + 3 * 2 = 1 1 , es.i = 5 + 3 * 3 «= 14, and es^ = 5 + 3 * 4 = 17, 
hence es = 17. 
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The values of /r/, i.e., the number of blocks in which a movie can be split, are 
given m table 1 for an offset zero and for different values of r. The series converge to power 
series, with bases of about 1.75, 2.42, 2.62, and e «2.72, for r=2, 3, 4, and ocj respectively. 
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Table 1. 

5 

The last column corresponds to having no limit on the number of client 
channels. Using the above values of Ac, the maximum waiting time is given by a jfraction l/hc 
of the movie length when using c channels. If a positive offiset o is used, the general formula 
for the maximum waiting time is a fraction (o+l)/hc of the movie length, 

10 In the previous sections, the number dt of sub-channels of channel i is fixed, 

given by equation (1). It should be noted that also different values may be used to get a better 
solution in terms of the number of blocks into which a movie can be split To this end, a first- 
order optimization can be supplied by exploring per chaimel i a number of different values 
around the target value given in (1), calculating the resulting number of blocks that can be fit 

15 into diannel /, and takmg the number of sub-chaxmels for which chaimel i can contain the 

highest number of blocks. Note that this is done per individual chaimel^ i.e., no back-tracking 
to previous channels occurs, to avoid an exponential run time for a straightforward 
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implementation. This may lead to sub-optimal solutions, as choosing a different nmnber of 
sub-channels in diannel j to get a higher number of blocks in it may cause the end time e,to 
increase, thereby increasing the start time si+r of channel i+r, which may in turn decrease the 
number of blocks that can be fit into this channel. Nevertheless, this first-order optimization 
gives good results as is diown in table 2. The new values of hi are given for an offeet zero 
and for different values of r. Although the numbers are higher than the ones in the previous 
table, the bases of the power series are the same as those of table 1. 





r=2 
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T=4 




r=oo 
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1 




1 




1 




1 




f = 2 


3 




3 




3 




3 




1 = 3 


6 




8 




8 




8 




i = 4 


11 




18 


(+1) 


20 




20 




1 = 5 


21 


(+1) 


41 


(+2) 


47 




50 




i = 6 


42 


(+4) 


94 


(+8) 


115 


(+2) 


127 


(+3) 


z = 7 


81 


(+13) 


218 


(+20) 


287 


(+11) 


328 


(+12) 


1 = 8 


148 


(+26) 


510 


(+43) 


728 


(+36) 


859 


(+37) 


i = 9 


269 


(448) 


1213 


(+111) 


1868 


(+98) 


2283 


(+107) 


i=10 


478 


(+81) 


2908 


(+276) 


4831 


(+284) 


6112 


(+294) 


i=ll 


841 


(+133) 


6993 


(+685) 


12543 


(+743) 


16459 


(+813) 


z=12 


1487 


(+243) 


16869 


(+1677) 


32685 


(+1937) 


44484 


(+2225) 


i=13 


2627 


(+432) 


40749 


(+4077) 


85391 


(+5118) 


120485 


(+6065) 


1=14 


4617 


(+755) 


98625 


(+9915) 


223390 


+13363) 


326795 


+16511) 


1=15 


8058 


(+1301) 


238841 


(+24049) 


584993 


(+34995) 


887124 


(+44915) 



10 Table 2. 



15 



in ttie remainder, the values of table 1 for the conventional Pagoda protocol 

will be used. 

In the description so fer, it has been assumed that titles have a constant bit rate 
(CBR). The transmission schemes, however, can easily be adapted to cope with variable bit 
rate (VBR) streams. The time at which block fcmust have arrived, which is given by o+k for 
CBR streams, is tiien given by a fimction o+t(k). Here, t(k) is an increasing function, that 
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describes fhe way fho stream is to be played out in time. The effect on the transmission 
scheme is as follows. If block k is transmitted in chamel which starts at time 5/, then it must 
be broadcasted with a period of at most o-^t(k)-(srl)^ Hence, the target value for the number 
of sub-channels, as given iu equation (1), now becomes 



Network assumptions 

In the remaiader, examples are given for a hierarchical network as shown in 
Fig. 1. It is assumed ttiat the main bottleneck is given by the edacities of the upstream and 
downstream links fix>m the homes to tiie fiber nodes. M the example, it is assumed that the 
cq)acities of the downstream Unks from the fiber nodes to the homes is 20 Mb/s. Assuming a 
video transmission rate of 5 Mb/s, this implies that 4 video channels can be downstreamed . 
per home. In the examples, it is assumed that there are no practical limitations on bandwidth 
above the fiber nodes. Further, it is assumed that it is desired to have a collection of 1000 
movies, which each last 6000 seconds (100 minutes). The size of a movie is hence 30 Gb, or 
3.75 GB. Aiming at a maximum response time of about one second, and a limit of r=3 
chamiels to be tapped, table 1 indicates that 1 1 transmission channels should be used, wh^e a 
movie can be split into 6308 blocks, and the actual maximum response time is 6000/6308 « 
0.95s. Generating the 11 transmission channels of all 1000 movies would use 55 Gb/s. It will 
be clear that this well above the capacity of the lowest level of the network where the 
capacity is in the order of 1 .5 Gb/s. 

FUtering according to the invention 

A drawback of the conventional Pagoda NVoD broadcasting scheme, or other 
similar NVoD schemes, is that all tides are continuously broadcast in full occupying a lot of 
bandwidth. This may not be a major problem for popular movies, with many receivers 
receiving the title, but can be a significant waste of bandwidth for unpopular titles. In the 
known systems, unpopular movies get the same amount of bandwidth allocated as popular 
movies. According to the invention, the number of used channels is decreased by not 




this sub-chaimel, is then given by = p^j = 




The rest of the computations remain the same. 
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transniitting blocks that are not required to serve a user request. Fig. 5 iUustrates for three 
initial user requests, indicated by the arrows, the blocks that are actually read by the 
receivers, using the Pagoda schedule. Those blocks are indicated in gray. All other blocks are 
broadcast but not consumed, wasting bandwidth. It is observed that in Pagoda-like schedules, 
a receiver only taps a channel between the receiver-specific start and end tune. All other 
repetitions of the block sequence assigned to the channel are not received by that receiver 
(but possibly by other receivers). The same observation applies at the sub-channel level, i.e., 
each sub-channel only has to be tapped by a receiver between the specific start and end time 
for the receiver for that sub-channel. As a consequence, a block only has to be transmitted if 
it fells within read interval for a certain request (i.e. at least one receiver requires a sequence 
or block of the sequence transmitted via the block/sub-channel or channel). If there is no such 
request, the block does not need to be transmitted, and the bandwidth can be used for other 
purposes. As a result, the average number of channels used simultaneously can be much 
lower than the worst case number of 1 1,000. So, if a request occurs at time then sub- 
channel j of channel i should be active from tune \mit ^hs/ untQ time unit i.e., at time 
units X for which t+st <x<t\-eij. The other way around, if at a time unit a: it is sub-channel/s 
turn, then it has to transmit a block if and only if there has been a request at a time t for which 

The probability of a request of any user in a time unit for a movie/is denoted 
byp/. If in a certain time unit it is the turn of sub-channely of channel then the probability 
that it needs to transmit a block is given by 

assuming the requests in different time units to be independent. For the example of Fig.5, this 
gives 

Pfxo =1-(1-P/)^ 
P/Ai =l-(l-P/)*» 

as ii3==2, n3,o=l, and W3,i=2, which corresponds to the probability of an arrival m an interval of 
two time units and four time units, respectively. The expected fraction of flie blocks that 
channel i of movie/has to transmit is hence given by 

and the expected total number of channels that have to transmit a block for movie/is given 
by 
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c 

Now, assuming a Poisson amval process with parameter \ then the arrival 
probability in a time luait is given by 

5 where u is the length of a time unit. Fig.6 shows vertically the expected number of used 
channels for one movie, for different arrival rates of 10* receivers per hour (x is shown 
horizontally), on a logarithmic scale. 

Assuming 1000 movies, of which 31,1 15, 200, 285, and 369 movies have a 
probability of 0.01, 0.0316, 0.001, 0.00316, and 0.0001, of being selected, respectively, and 

10 we assume an arrival rate of 200,000 requests per 6,000 seconds, then the expected total 
number of used channels is about 5,533 compared to 11,000. If the arrival rate is decreased 
by a factor 1 0, for instance since not aU users will watch a movie, the number goes even 
furthCT down to 2,858. 

In an ideal situation, with respect to the average number of used chaimels, a 

1 5 new transmission of a block k is scheduled as late as possible. Note that whereas this 

schedule gives the lowest average number of xised channels, it does not bound the maximum 
nimiber of used channels, which makes it less suitable for practical use. It is therefore only 
used to derive a lower bound on the number of used channels. This means that if a new 
request arrives in time unit block k is scheduled for transmission in time unit t^o+k^ Hie 

20 time unit in which it is needed for playout. In this way, all requests that arrive in time units 
f+1,. , ., ^+a+jt-l can tap tihds transmission of block ky i.e., tiie considered transmission of 
block k can be reused for as many other requests as possible. Only when a new request 
arrives in time unit /+o+/c or later, a new transmission of block k is scheduled. The fraction of 
time that block k is transmitted is now determined, again assuming a Poisson arrival rate of X 

25 and a time unit of length u. As derived before, the probability that a request arrives in a time 
unit then equals 

/? = l-e-^. 

The above procedure can be modeled by means of a Markov chain, as 
indicated in Fig.7. In this chain, a state 0 is dejSned when the system is waiting for a new 
30 request When a request has arrived, counting starts from 1 to o+Ai hence states 1,. . are 
introduced. If the system is in state 0, counting starts when a request arrives, which happens 
with probability p. If this happens, a transition is made to state 1, otherwise the system stays 



20 
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in state 0. If the system is in state ir=l,. . .,o+A:-l, counting continues, hence the next state is 
state 5+1 with probsibility 1. If the system is in the last state 0+^ a tiransmission takes place. 
If in this same time imit a new request arrives, which again happens with probabiUtyp, then 
counting is re-started, i.e., the system goes to state 1 again. Otherwise, it goes to the waiting 
5 state 0. 

The probability that the system is in state s in equilibrium is indicated by ps. 
Looking at the chain, it can be observed that every time state 1 is reached also states 2,, . .,o+k 
will be reached, hence it holds that 

jPl=y2=,..=/7a*-Jfc 

10 Next, considering the transitions from and to state 0, this gives 



hence 



The sum of the probabilities has to be 1, so 
15 Po^A 



which gives 



Pa^kA 1 + 0 + ^ . 

\P ) 



This is the fraction of time that block k is transmitted, hence, if a movie 
consists of n blocks, the average nuinber of used chamiels given by 

Choosiag the size m of a time unit very small, and assuming a maximum 
waiting time of w and length / of a movie, then we have o « w/«, n « //«, and/7=l-e"'*, whidi 
gives an average number of used chaimels given by 

yf — i-T — l+w/M+Arl . 

25 For sufficiently small m, this can be {Approximated by 
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As j*(a + jc)"' dx = ln((a + 6) / «), this can be rewritten into 



In 



1- 



1 ^ 

— 1+w/m+//« 



.-An 



-1+w/tt 



J «-Kw+0(g^-i)^ 
\ u+w(e*'-l) J' 



If M * 0, this converges to 
l^Xw ) 

5 Fig.8 shows this lower bound on the average number of used channels 

(vertically) for the same p^^yimnTn response time w=0.95 s and tiie same movie length 
/=6000 s for an arrival rate of 10* clients per hour {x is shown horizontally). 

In the embodiment described above, the transmission schedule is maximally 
adaptive, in the sense that not only the decision whether or not a block is transmitted depends 

10 on whether or not a request occurs, but also the time unit in which the transmission is 

scheduled (as late as possible). In an alternative embodiment, the schedule of the blocks is 
fixed, and only the decision is made whether or not a block is transmitted. For fixed 
transmission schedules, block k is optimally transmitted once every o^k time units. If a 
request then occurs in a time unit there is exactly one transmission of block k scheduled 

15 that can be received in time. It is not possible to skip a transmission of block k and wait until 
the next one, as this next one is o^k time units later, and hence will be too late for playout. 
Whether or not block k should be transmitted, in its prescheduled tkne unit, now only 
depends on whether or not a request has occurred during the past o+Ar time units, which 
happens with probability 

20 l-e-^(^*>, 

and hence the average number of used channels is given by 

Again, choosing the size m of a time unit very small, and assuming a maximimi 
waiting time of w and length / of a movie, we have o « w/u and n » //«, this gives an average 
25 number 

^(W'\'uk)/u* 

For suflSciently small u this can again be approximated by 



PHNLQ21206EPP 



18 02.12.2002 



t 



ax. 



which, using y= wHu is equal to 

y 

Note that the dependency on u has disappeared in this equation. The results 
obtained by the alternative embodiment are shown in Fig.9. This figure shows the second 
bound on the average number of used channels (vertically) for the same maximum response 
time w= 0,95 s and the same movie length /=6000 s for an arrival rate of 10* clients per hour 
horizontally). 

Fig. 10 combines the graphs of the average number of used channels of Figs. 6, 
8 and 9. The top line corresponds to the used selective pagoda scheme, the bottom line to the 
lower bound given by the fully adaptive scheme, and the middle line to the selective 
transmission with optimal periods. Fig.l 1 shows the ratio betweCTi the top line and the lower 
boimd and the ratio between the middle line and the lower bound. As can be seen, the 
selective pagoda scheme is always within 32% from the lower bound. The difference 
between the two lines indicates what can be gained by choosing a better NVoD schedule. To 
get below the second line, also the moments of transmission must become adaptive. 

In the literature, several ways to lower the bandwidth requirement for 
unpopular movies have been proposed. One way is to use broadcasting only for the latter part 
of a movie, and transmit the first (small) part of a movie more or less on request, for each 
user individually. A drawback of fliis method is that popular movies require more bandwidth 
than with an all-broadcast approach. To overcome this, one should know the popularity of a 
movie, and choose the proper balance between the first, on-demand part and the latter, 
broadcasted part. Another way is to dynamically schedule block transmissions. Upon a 
request, one checks which blocks are still to come, and inserts the missing blocks in a 
dynamic way into the schedule. A drawback of this method is that a heuristic is used to 
schedule the blocks, which may perform worse than an optimal offline broadcast scheme. 
The benefit of the schedule according to the invention is that (asymptotically) optimal offline 
broadcast schemes can be used, and only on-line it needs to be determined whether or not a 
block should be broadcast. In this way, tiie required bandwidth automatically ad25>ts to the 
popularity of a movie, and a (near) optimal solution is obtained for the entire popularity 
range. 
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It should be noted that the above-mentioned embodiments illustrate rather than 
limit the invention, and that those skilled in the art will be able to design many alternative 
embodiments without departing from the scope of the appended claims. In the claims, any 
reference signs placed between parentheses shall not be construed as limiting the claim. The 
5 words "comprising" and "including" do not exclude the presence of other elements or steps 
than those listed in a claim. The invention can be implemented by means of hardware 
comprising several distinct elements, and by means of a suitably programmed computer, in 
the sj^tan claims enumerating several means, several of these means can be embodied by 
one and flie same item of hardware. The computer program product may be stored/distributed 
10 on a suitable medium, such as optical storage, but may also be distributed in other forms, 
such as bemg distributed via the network of the broadcasting system, Internet or wkeless 
telecommunication systems. 
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1 . A broadcast system for broadcasting at least one title using a near-video-on- 

demand broadcasting protocol; the system includes: 
a plurality of broadcast receivers; 

a hierarchical network of data distributors starting &om a central distributor 
5 through at least one layer of intermediate distributors to the broadcast receivers for 
broadcasting the title as a sequence of data blocks; 

at least one filter controller operative to receive requests from broadcast 
receivers for the supply of the title and for controlling at least one intermediate distributor to 
filter out data blocks of the title that have not been requested by receivers hi«rarchically 
1 0 below the intermediate distributor. 



2. A broadcast system as claimed in claim 1, wherein data blocks of the title are 

broadcast via a plurality of channels using sequential time-slots within the channels 

according to a near-video-on-demand schedule that for each data block of the title prescribes 
15 a time-slot and channel for broadcasting the data block relative to a time-slot used for 

broadcasting a first data block of the title; data blocks assigned to a channel being repeatedly 

broadcast within the chaimel; the filter controller being operative to: 

store information on all receivers hierarchically below the intermediate 

distributor that have requested the title (hereinafter "interested receivers") to enable the filter 
20 controller to determine for each channel whether at least one of the interested receivers needs 

to receive a data block assigned to the channel; and 

control the intermediate distributor to filter out a chaimel if no interested 

receiver needs to receive a data block assigned to the channel. 

25 3. A broadcast S3rstem as claimed in claim 2, wherein the near-video-on-demand 

schedule prescribes that data blocks of the titie are broadcast via c parallel equal capacity 
channels of the broadcast system, where each broadcast chaimel is associated with a 
respective sequential channel number; the titie being divided in a plurality of consecutive 
data block sequences; each block sequence being assigned to one respective channel 
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according to the sequence of the channel numbers; each channel repeatedly broadcasting the 
blocks of the assigned block sequence; the broadcast receiver having a capadty to 
simultaneously receive a pluraHty r (l<r^c) of the channels; the broadcast receiver bdng 
operative to receive a title by starting reception of the sequentially lowest r channels and each 
5 time in response to havmg received all blocks of the block sequence of a channel i terminate 
reception of channel i and start reception of channel r+i until all block sequences have been 
received. 

4. A system as claimed in claim 3, wherein the near-video-on-demand schedule 

10 prescribes tiiat data blocks of the title are broadcast via c parallel equal capacity channels of 
the broadcast system, where each broadcast channel is associated witii a respective sequential 
channel number; a plurality of tiie broadcast channels includmg a plurahty of time- 
sequentially interleaved sub-channels; tiie number of sub-channels in a channel being 
monotonous non-decreasing with the channel number, tiie sub-channels in a channel being 
15 associated witii a respective sequential sub-channel number; tiie titie being divided in a 
plurality of consecutive data block sequences; each block sequence bemg assigned to one 
respective sub-channel according to the sequence of the channel numbers and of tiie sub- 
channel numbers; each sub-channel repeatedly broadcasting tiie assigned block sequence; the 
broadcast receiver having a capacity to simultaneously receive all sub-chamels of a plurality 
20 r i\<r ^ c) of tiie channels; tiie broadcast receiver being operative to receive a title by starting 
recq)tion of aU sub-channels of tiie sequentially lowest r channels and each time in response 
to havmg received all blocks of tiie block sequence of a sub-channel of channel i terminating 
reception of tiie sub-channel m channel i and starting reception of a sub-channel of channel 
r+i until all block sequences have been received; tiie filter contooUer bemg operative to 
25 control tiie intermediate distributor to filter out a sub-channel if no interested receiver needs 
to receive a data block assigned to the sub-channel. 

5. A system as claimed in claim 2, tiie filter contiroller is operative to use tiie. 

stored information to determine for each chamiel whetiier at least one interested recover 
30 needs to receive a data block in a next time-slot of tiie channel and to control tiie intermediate 
disfidbutor to filter out tiie datablock if no interested receiver needs to rec«ve tiie datablock 
in the next time-slot. 



6. 



A system as claimed m claim 5, wherem ttie channels are time-multiplexed. 
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7. A system as claimed in claim 3, wherein the intemiediate distributor is 
operative to extract data blocks broadcast via the r channels to be received by at least one 
interested receivers and transmit the ejctracted data blocks via predetermined channels to the 

5 interested receivers. 

8. A system as claimed in claim 1, wherein the intermediate distributor includes 
tiie filter controller. 

10 9. A system as claimed in claim 1 , wherein at least one of the broadcast receivers 

is operative to commimicate to the filter controller via an upstream channel of the broadcast 
system. 

10. A method of broadcasting at least one title as a sequence of data blocks 

1 5 through a hierarchical network of data distributors starting from a central distributor through 
at least one layer of intermediate distributors to the broadcast receivers using a near-video- 
on-demand broadcasting protocol; the method including: 

receiving requests firom broadcast receivers for the supply of the title; 
ia at least one intermediate distributor filtering out data blocks of the title that ' 
20 have not been requested by receivers hierarchically below the intermediate distributor. 

11. A broadcast receiver for use in a broadcast system as claimed in claim 1 that 
includes a hierarchical network of data distributors starting fi'om a central distributor through 
at least one layer of intermediate distributors to the broadcast receivers for broadcasting a 

25 title as a sequence of data blocks using a near-video-on-dCTiand broadcasting protocol via 
downstream channels of the system; the broadcast receivers being operative to commimicate 
to a filter controller via an upstream channel of the broadcast system to enable the filter 
controller to control at least one intermediate distributor hierarchically above the broadcast 
receiver to filter out data blocks of the title that have not been requested by receivers 

30 hierarchically below the intermediate distributor. 



12. A filter controller for use in a broadcast system as claimed in claim 1 that 

includes a hierarchical network of data distributors starting fiom a central distributor tbrougih 
at least one layer of intermediate distributors to the broadcast receivers for broadcasting a 
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title as a sequence of data blocks using a near-video-on-demand broadcasting protocol via 
downstream channels of the system; the filter controller being operative to receive requests 
from broadcast receivers for the supply of the title and for controlling at least one 
intemiediate distributor to filter out data blocks of the title that have not been requested by 
recdvers hierarchically below the intermediate distributor. 

13. An intermediate distributor for use in a broadcast system as claimed in claim 1 

that includes a hierarchical network of data distributors starting fix)m a central distributor 
through at least one layer of intermediate distributors to the broadcast receivers for 
broadcasting a title as a sequence of data blocks using a near-video-on-demand broadcasting 
protocol via downstream channels of the system; the intermediate distributor being operative 
to filter out data blocks of the title that have not been requested by receivers hierarchically 
below the intermediate distributor. 
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ABSTRACT: 



A broadcast system 100 for broadcasting at least one title using a near-video- 
on-demand broadcasting protocol includes a plurality of broadcast receivers 150. A 
hierarchical network of data distributors starts from a central distributor 110 through at least 
one layer of intermediate distributors 120, 130, 140 to the broadcast receivers for 
5 broadcasting the title as a sequence of data blocks. A least one filter controller 1 80 receives 
requests from broadcast receivers for the supply of the title and controls at least one 
intermediate distributor to filter out data blocks of the title that have not been requested by 
receive hierarchically below the intermediate distributor. 

10 Fig. 1 
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